MongoDB তে কুয়েরি অপারেটরগুলি ব্যবহার করা হয় ডেটা অনুসন্ধান এবং প্রক্রিয়া করার জন্য। এই অপারেটরগুলি বিভিন্ন ধরনের শর্তের ভিত্তিতে ডেটা নির্বাচন করতে সহায়তা করে। MongoDB তে তিন ধরনের প্রধান কুয়েরি অপারেটর রয়েছে: তুলনা অপারেটর, লজিক্যাল অপারেটর, এবং এলিমেন্ট অপারেটর।
তুলনা অপারেটরগুলি ডেটার মানের ভিত্তিতে ডেটা অনুসন্ধান করতে ব্যবহৃত হয়।
$eq
(সমান): ডেটার মানের সাথে সমান থাকা ডকুমেন্টগুলি মেলে।
db.collection.find({ age: { $eq: 30 } })
$ne
(অসমান): ডেটার মানের সাথে অসমান থাকা ডকুমেন্টগুলি মেলে।
db.collection.find({ age: { $ne: 30 } })
$gt
(বড়): ডেটার মান যেগুলোর থেকে বড়, সেগুলিকে মেলে।
db.collection.find({ age: { $gt: 30 } })
$gte
(বড় অথবা সমান): ডেটার মান যেগুলোর থেকে বড় অথবা সমান, সেগুলিকে মেলে।
db.collection.find({ age: { $gte: 30 } })
$lt
(ছোট): ডেটার মান যেগুলোর থেকে ছোট, সেগুলিকে মেলে।
db.collection.find({ age: { $lt: 30 } })
$lte
(ছোট অথবা সমান): ডেটার মান যেগুলোর থেকে ছোট অথবা সমান, সেগুলিকে মেলে।
db.collection.find({ age: { $lte: 30 } })
$in
(ভিতরে): একটি নির্দিষ্ট মান যেগুলোর মধ্যে থাকে, সেগুলি মেলে।
db.collection.find({ age: { $in: [30, 40, 50] } })
$nin
(ভিতরে নয়): একটি নির্দিষ্ট মান যেগুলোর মধ্যে নেই, সেগুলি মেলে।
db.collection.find({ age: { $nin: [30, 40, 50] } })
লজিক্যাল অপারেটরগুলি একাধিক শর্তের ভিত্তিতে ডেটা নির্বাচন করতে ব্যবহৃত হয়।
$and
(এবং): একাধিক শর্তের মধ্যে সব শর্ত মেনে চলা ডকুমেন্টগুলি মেলে।
db.collection.find({ $and: [{ age: { $gte: 30 } }, { age: { $lt: 40 } }] })
$or
(অথবা): একাধিক শর্তের মধ্যে যেকোনো একটি শর্ত পূর্ণ হলে ডকুমেন্ট মেলে।
db.collection.find({ $or: [{ age: { $lte: 30 } }, { age: { $gte: 40 } }] })
$not
(নট): একটি শর্তের বিপরীত ডকুমেন্ট মেলে।
db.collection.find({ age: { $not: { $gte: 30 } } })
$nor
(অথবা নয়): একাধিক শর্তের মধ্যে সব শর্ত পূর্ণ না হলে ডকুমেন্ট মেলে।
db.collection.find({ $nor: [{ age: { $gte: 30 } }, { age: { $lte: 20 } }] })
এলিমেন্ট অপারেটরগুলি ডেটার উপস্থিতি বা ডেটার টাইপ পরীক্ষা করতে ব্যবহৃত হয়।
$exists
(অস্তিত্ব): একটি ফিল্ড ডকুমেন্টে রয়েছে কিনা তা চেক করতে ব্যবহৃত হয়। এটি true
বা false
হতে পারে।
true
: ফিল্ডটি বিদ্যমান ডকুমেন্টগুলি মেলে।false
: ফিল্ডটি অনুপস্থিত ডকুমেন্টগুলি মেলে।db.collection.find({ age: { $exists: true } })
db.collection.find({ age: { $exists: false } })
$type
(টাইপ): একটি ফিল্ড নির্দিষ্ট BSON টাইপের কিনা তা চেক করতে ব্যবহৃত হয়।
db.collection.find({ age: { $type: "int" } })
db.collection.find({ age: { $type: 16 } }) // 16 হল BSON টাইপ `int`
তুলনা অপারেটর ব্যবহার করে: বয়স ৩০ এর কম বা ৬০ এর বেশি ব্যবহারকারীদের খুঁজুন।
db.users.find({ age: { $lt: 30, $gt: 60 } })
লজিক্যাল অপারেটর ব্যবহার করে: বয়স ৩০ এর বেশি বা ২০ এর কম ব্যবহারকারীদের খুঁজুন।
db.users.find({ $or: [{ age: { $gt: 30 } }, { age: { $lt: 20 } }] })
এলিমেন্ট অপারেটর ব্যবহার করে: যেখানে age
ফিল্ড উপস্থিত।
db.users.find({ age: { $exists: true } })
$in
ব্যবহার করে: বয়স ২৫, ৩০ অথবা ৩৫ এর মধ্যে ব্যবহারকারীদের খুঁজুন।
db.users.find({ age: { $in: [25, 30, 35] } })
MongoDB তে তুলনা অপারেটর, লজিক্যাল অপারেটর, এবং এলিমেন্ট অপারেটর ডেটাবেসে ডেটা অনুসন্ধানে অত্যন্ত শক্তিশালী টুল হিসেবে কাজ করে। তুলনা অপারেটর ব্যবহার করে ডেটার মানের ভিত্তিতে কুয়েরি করা যায়, লজিক্যাল অপারেটর ব্যবহার করে একাধিক শর্তকে যুক্ত বা বিপরীতভাবে কাজ করা যায়, এবং এলিমেন্ট অপারেটর ব্যবহার করে ডেটার উপস্থিতি বা টাইপ চেক করা যায়। এই অপারেটরগুলি MongoDB ডেটাবেসে খুবই নমনীয় এবং জটিল কুয়েরি তৈরি করতে সহায়তা করে।